# RUN:     llvm-mc -triple=aarch64  -mattr=+bf16  -disassemble < %s      | FileCheck %s
# RUN:     llvm-mc -triple=aarch64  -mattr=+v8.6a -disassemble < %s      | FileCheck %s
# RUN: not llvm-mc -triple=aarch64  -mattr=-bf16  -disassemble < %s 2>&1 | FileCheck %s --check-prefix=NOBF16
# RUN: not llvm-mc -triple=aarch64                -disassemble < %s 2>&1 | FileCheck %s --check-prefix=NOBF16


[0x62,0xfc,0x44,0x2e]
[0x62,0xfc,0x44,0x6e]
# CHECK: bfdot   v2.2s, v3.4h, v4.4h
# CHECK: bfdot   v2.4s, v3.8h, v4.8h
# NOBF16: warning: invalid instruction encoding
# NOBF16-NEXT: [0x62,0xfc,0x44,0x2e]
# NOBF16: warning: invalid instruction encoding
# NOBF16-NEXT: [0x62,0xfc,0x44,0x6e]

[0x62,0xf0,0x44,0x4f]
[0x62,0xf0,0x64,0x4f]
[0x62,0xf8,0x44,0x4f]
[0x62,0xf8,0x64,0x4f]
# CHECK: bfdot  v2.4s, v3.8h, v4.2h[0]
# CHECK: bfdot  v2.4s, v3.8h, v4.2h[1]
# CHECK: bfdot  v2.4s, v3.8h, v4.2h[2]
# CHECK: bfdot  v2.4s, v3.8h, v4.2h[3]
# NOBF16: warning: invalid instruction encoding
# NOBF-NEXT: [0x62,0xf0,0x44,0x4f]
# NOBF16: warning: invalid instruction encoding
# NOBF6-NEXT: [0x62,0xf0,0x64,0x4f]
# NOBF16: warning: invalid instruction encoding
# NOBF6-NEXT: [0x62,0xf8,0x44,0x4f]
# NOBF16: warning: invalid instruction encoding
# NOBF6-NEXT: [0x62,0xf8,0x64,0x4f]


[0x62,0xf0,0x44,0x0f]
[0x62,0xf0,0x64,0x0f]
[0x62,0xf8,0x44,0x0f]
[0x62,0xf8,0x64,0x0f]
# CHECK: bfdot  v2.2s, v3.4h, v4.2h[0]
# CHECK: bfdot  v2.2s, v3.4h, v4.2h[1]
# CHECK: bfdot  v2.2s, v3.4h, v4.2h[2]
# CHECK: bfdot  v2.2s, v3.4h, v4.2h[3]
# NOBF16: warning: invalid instruction encoding
# NOBF-NEXT: [0x62,0xf0,0x44,0x0f]
# NOBF16: warning: invalid instruction encoding
# NOBF6-NEXT: [0x62,0xf0,0x64,0x0f]
# NOBF16: warning: invalid instruction encoding
# NOBF6-NEXT: [0x62,0xf8,0x44,0x0f]
# NOBF16: warning: invalid instruction encoding
# NOBF6-NEXT: [0x62,0xf8,0x64,0x0f]


[0x62,0xec,0x44,0x6e]
[0x83,0xec,0x45,0x6e]
# CHECK: bfmmla  v2.4s, v3.8h, v4.8h
# CHECK: bfmmla  v3.4s, v4.8h, v5.8h
# NOBF16: warning: invalid instruction encoding
NOBF16-NEXT: [0x62,0xec,0x44,0x6e]
# NOBF16: warning: invalid instruction encoding
# NOBF16-NEXT: [0x83,0xec,0x45,0x6e]


[0xa5,0x68,0xa1,0x0e]
[0xa5,0x68,0xa1,0x4e]
# CHECK: bfcvtn   v5.4h, v5.4s
# CHECK: bfcvtn2  v5.8h, v5.4s
# NOBF16: warning: invalid instruction encoding
# NOBF16-NEXT: [0xa5,0x68,0xa1,0x0e]
# NOBF16: warning: invalid instruction encoding
# NOBF16-NEXT: [0xa5,0x68,0xa1,0x4e]

[0x65, 0x40, 0x63, 0x1e]
# CHECK: bfcvt  h5, s3
# NOBF16: warning: invalid instruction encoding
# NOBF16-NEXT: [0x65, 0x40, 0x63, 0x1e]
